import './public-path';
import Vue from 'vue';
import App from './App.vue';
import router from './router';

Vue.config.productionTip = false;

let instance = null;
function render(props = {}) {
  const { container, appContent } = props;

  instance = new Vue({
    router,
    data() {
      return {
          content: appContent
      }
    },
    render: h => h(App),
  }).$mount(container ? container.querySelector('#app') : '#app');
}

// 独立运行时
if (!window.__POWERED_BY_QIANKUN__) {
  render();
}

export async function bootstrap() {
  console.log('[vue] vue app bootstraped');
}
export async function mount(props) {
  Vue.prototype.$actionChange = props.onGlobalStateChange;
  Vue.prototype.$setAction = props.setGlobalState;
  console.log(props.appContent.str)
  render(props);
}
export async function unmount() {
  instance.$destroy();
  instance.$el.innerHTML = '';
  instance = null;
}